﻿//==================================================================
// Copyright (C) 2011 深圳市中旭企业管理股份有限公司
// 文件名: V_TrIndagateSubject.cs
// 作 者：代码自动生成
// 日 期：2011-11-8 12:41:14
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;

namespace ZX.TR.Library
{
	/// <summary>
    /// 
    /// </summary>
	[Serializable]
    [Table(Name = "V_TrIndagateSubject")]
    [ZX.DBModule.Table("V_TrIndagateSubject", "TrIndagateID")]
	public class V_TrIndagateSubject: ZX.DBModule.BaseEntity
	{
        
        #region Business Methods 业务方法
       
		/// <summary>
        /// 调研ID
        /// </summary>
        private static PropertyInfo< Guid > TrIndagateIDProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< Guid >("TrIndagateID"));
        [Column]
        public Guid TrIndagateID
        {
            get { return GetProperty(TrIndagateIDProperty); }
            set { SetProperty(TrIndagateIDProperty, value); }
        }
		/// <summary>
        /// 题目ID
        /// </summary>
        private static PropertyInfo< Guid > TrSubjectInfoIDProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< Guid >("TrSubjectInfoID"));
        [Column]
        public Guid TrSubjectInfoID
        {
            get { return GetProperty(TrSubjectInfoIDProperty); }
            set { SetProperty(TrSubjectInfoIDProperty, value); }
        }
		/// <summary>
        /// 序号
        /// </summary>
        private static PropertyInfo< int > SequenceProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< int >("Sequence"));
        [Column]
        public int Sequence
        {
            get { return GetProperty(SequenceProperty); }
            set { SetProperty(SequenceProperty, value); }
        }
		/// <summary>
        /// 答题人
        /// </summary>
        private static PropertyInfo<Guid> AddUserProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<Guid>("AddUser"));
        [Column]
        public Guid AddUser
        {
            get { return GetProperty(AddUserProperty); }
            set { SetProperty(AddUserProperty, value); }
        }
		/// <summary>
        /// 评分人
        /// </summary>
        private static PropertyInfo< Guid > CheckIDProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< Guid >("CheckID"));
        [Column]
        public Guid CheckID
        {
            get { return GetProperty(CheckIDProperty); }
            set { SetProperty(CheckIDProperty, value); }
        }
		/// <summary>
        /// 选择、填写
        /// </summary>
        private static PropertyInfo< string > AnswerProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< string >("Answer"));
        [Column]
        public string Answer
        {
            get { return GetProperty(AnswerProperty); }
            set { SetProperty(AnswerProperty, value); }
        }
		/// <summary>
        /// 得分
        /// </summary>
        private static PropertyInfo< decimal > PointProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< decimal >("Point"));
        [Column]
        public decimal Point
        {
            get { return GetProperty(PointProperty); }
            set { SetProperty(PointProperty, value); }
        }
		/// <summary>
        /// 答题时间
        /// </summary>
        private static PropertyInfo< DateTime > AnswerTimeProperty = RegisterProperty(typeof(V_TrIndagateSubject),new PropertyInfo< DateTime >("AnswerTime"));
        [Column]
        public DateTime AnswerTime
        {
            get { return GetProperty(AnswerTimeProperty); }
            set { SetProperty(AnswerTimeProperty, value); }
        }

        /// <summary>
        /// 题目名称
        /// </summary>
        private static PropertyInfo<string> SubjectNameProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<string>("SubjectName"));
        [Column]
        public string SubjectName
        {
            get { return GetProperty(SubjectNameProperty); }
            set { SetProperty(SubjectNameProperty, value); }
        }
        /// <summary>
        /// 题目类型
        /// </summary>
        private static PropertyInfo<string> SubjectTypeProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<string>("SubjectType"));
        [Column]
        public string SubjectType
        {
            get { return GetProperty(SubjectTypeProperty); }
            set { SetProperty(SubjectTypeProperty, value); }
        }
        /// <summary>
        /// 题目内容
        /// </summary>
        private static PropertyInfo<string> SubjectContentProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<string>("SubjectContent"));
        [Column]
        public string SubjectContent
        {
            get { return GetProperty(SubjectContentProperty); }
            set { SetProperty(SubjectContentProperty, value); }
        }
        /// <summary>
        /// 参考答案
        /// </summary>
        private static PropertyInfo<string> RefAnswerProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<string>("RefAnswer"));
        [Column]
        public string RefAnswer
        {
            get { return GetProperty(RefAnswerProperty); }
            set { SetProperty(RefAnswerProperty, value); }
        }
        /// <summary>
        /// 题目分数
        /// </summary>
        private static PropertyInfo<decimal> SubjectPointProperty = RegisterProperty(typeof(V_TrIndagateSubject), new PropertyInfo<decimal>("SubjectPoint"));
        [Column]
        public decimal SubjectPoint
        {
            get { return GetProperty(SubjectPointProperty); }
            set { SetProperty(SubjectPointProperty, value); }
        }
		
        #endregion
        
        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "Answer");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Answer", 200));
            //base.AddBusinessRules();
        }
        #endregion
        
        #region Factory Methods 工厂方法

        public V_TrIndagateSubject(){}

        public static V_TrIndagateSubject New()
        {
            return DataPortal.Create< V_TrIndagateSubject>();
        }
        public static V_TrIndagateSubject Get(Guid V_TrIndagateSubjectID)
        {
            return DataPortal.Fetch< V_TrIndagateSubject>(new SingleLazyCriteria< V_TrIndagateSubject, Guid>(V_TrIndagateSubjectID, false));
        }
        public static void Delete(Guid V_TrIndagateSubjectID)
        {
            DataPortal.Delete(V_TrIndagateSubjectID);
        }

        //public override V_TrIndagateSubject Save()
        //{
            //return base.Save();
        //}
        #endregion
		
		#region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid V_TrIndagateSubjectID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
             using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("V_TrIndagateSubjectID").Equal(V_TrIndagateSubjectID);
                var data = db.Select< V_TrIndagateSubject>(q)[0];
                LoadProperty(TrIndagateIDProperty, data.TrIndagateID);
                LoadProperty(TrSubjectInfoIDProperty, data.TrSubjectInfoID);
                LoadProperty(SequenceProperty, data.Sequence);
                LoadProperty(AddUserProperty, data.AddUser);
                LoadProperty(CheckIDProperty, data.CheckID);
                LoadProperty(AnswerProperty, data.Answer);
                LoadProperty(PointProperty, data.Point);
                LoadProperty(AnswerTimeProperty, data.AnswerTime);

                LoadProperty(SubjectNameProperty, data.SubjectName);
                LoadProperty(SubjectTypeProperty, data.SubjectType);
                LoadProperty(SubjectContentProperty, data.SubjectContent);
                LoadProperty(RefAnswerProperty, data.RefAnswer);
                LoadProperty(SubjectPointProperty, data.SubjectPoint);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(TrIndagateIDProperty);
        }
        #endregion

	}
}

